INTRODUCTION 



This manual describes the functionality and provides the the- 
ory of operation for the Level 6 Model 43/53 Central Processor 
Unit (CPU) . 

1.1 GENERAL DESCRIPTION 

The CPU is a high-speed general purpose digital computer de- 
signed to process data from main memory and associated system 
devices. Its logic elements are fabricated on a 15- by 16-inch 
control board and a 12- by 14-inch four-layer CPU board. The CPU 
board is physically supported by the control board, hereafter re- 
ferred to as the controller, in a piggyback manner. The control- 
ler houses the CPU control logic including some of the CPU regis- 
ters, clock network, and Megabus* interface logic. The CPU board 
contains associated functional elements including the micropro- 
cessor. Random Access Memory (RAM), and bootstrap Programmable 
Read Only Memory (PROM). A Memory Management Unit (MMU) and 
cache memory are available as CPU options and, when included as 
part of the Model 43/53 system configuration, they are also 
housed on the CPU board. For details concerning the MMU and 
cache memory options, refer to the applicable documentation list- 
ed in subsection 1.2 

CPU communication with main memory and other units of the 
Level 6 system is over a common bus, called the Megabus (see 
Figure 1-1) . The interface signals between the CPU and the Mega- 

*Trademark of Honeywell Information Systems, Inc. 
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bus are shown in Figure 1-2. The CPU can also operate in a 
multi-processor environment consisting of up to four central pro- 
cessing units, and each CPU can communicate directly with the 
following optional processor type controllers over the Megabus. 

• Commercial Instruction Processor (ClP) 

• Scientific Instruction Processor (SIP) 

For details concerning the CIP and SIP options, refer to the 
appl icable documentation listed in subsection 1,2. 

The CPU uses hardware, with the aid of firmware, to communi- 
cate directly with the MMU or cache memory, to communicate with 
main memory over the system Megabus, and to decode all CPU in- 
structions, performing the necessary arithmetic, logical, or 
shift operations (see Figure 1-3). The following list provides 
additional information relative to the general characteristics of 
the CPU: 

i 

1. 8-, 16-, or 32-bit data 

2. Up to two megabytes of directly addressable main memory 

3. Bit, byte, word, and double-word registers 

4. Bit test, set, and mask capability 

5. 26 program visible general registers, including multiple 
accumulators, multiple address, index, and control regis- 
ters 

6. Immediate, register -to- register , and register-to-memory 
operations 

7. 64 vectored interrupt levels 

8. Stack/Queue handling 

9. Multiple vectored trap structure 

10. Hardware supported context save and restore 

11. Multiple addressing modes, including indexing, indirect, 
base plus displacement, program counter relative, auto 
increment/decrement , etc . 

12. Real-time clock and watchdog timer 

13. Power failure detection 

14. Automatic restart 

15. Bootstrap 

16. Writable Control Store (WCS) . 
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Figure 1-1 CPU Communications Block Diagram 
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Figure 1-2 CPU/Megabus Interface Signals 
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Figure 1-3 CPU Functional Block Diagram 
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1*2 REFERENCE DOCUMENTATION 

The following support documents for the Model 43/53 CPU con- 
tain supplementary information for the data presented in this 

manual . 



DESCRIPTION 

1. Model 53 CPU Manual - Volume 2 
(cache memory) 

2. Model 53 CPU Manual - Volume 3 
(MMU) 

3. Model 47 CPU Manual - Volume 2 
(CIP) 

4. Type CPF9503 Scientific Instr- 
uction Processor Manual 



ORDER 
NUMBER 

FQ30 
FW85 
FWS2 
FN30 



1.3 SOFTWARE VISIBLE REGISTERS 

Twenty six program visible registers, counters, and discrete 
signal lines are available for use by software to maintain soft- 
ware related data or instructions, and to display selected CPU 
status conditions for software interrogation. These elements 
include: 

• Seven base registers 

• Seven data registers 

• Indicator register 

• Seven mode registers 

• Program counter 

• Remote data descriptor base register 

• Status/security register 

• Stack pointer. 

The software application for each of the above is described 
in the following subsections. 

1.3.1 Base Registers (Bl Through B7) 

Seven base registers (Bl through B7) are located in the reg- 
ister file portion of the microprocessor (refer to subsection 
4.4.2), and maintain a 20-bit address of any procedure, data, 
array, or arbitrary location in memory. 

1.3.2 Data Registers (Dl Through D7) 

Seven data registers (Dl through D7) are located in the re- 
gister file portion of the microprocessor (refer to subsection 
4.4.2), and serve as 16-bit (10 through IF) general purpose re- 
gisters or accumulators. Bit 10 of each register is considered 
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the most significant bit. Each data register can also be used 
for post-indexing of addresses (i.e., as index registers). 

NOTE 

In software notation these registers are designated 
Rl through R7 . 

1*3.3 Indicator Register (I) 

The indicator register (I) contains several single bit indi- 
cators that provide temporary storage for overflow and program 

status information. 

1.3.4 Mode Registers (Ml Through M7) 

The mode registers (Ml through M7) reside in locations 1 
through 7 of the CPU Random Access Memory (RAM) , refer to sub- 
section 4.9.1. These registers retain mode information pertain- 
ing to the CPU and other processors (i.e., CIP and/or SIP), and 
can be modified by the MTM instruction. Currently, registers 
M2, M6 r and M7 are reserved for future use, while the remaining 
four registers (Ml and M3 through ME>) define the following system 
features: 

• Ml - CPU trace and overflow trap masks 

• M3 - CIP truncation and overflow trap masks 

• M4 - SIP memory and accumulator length control and round/ 
truncate mode control 

• M5 - SIP exponent underflow, significance,- and precision 
error trap masks. 

1.3.5 Program Counter (P Register) 

The program counter (or P register) normally contains the 
storage address of the next instruction to be executed by the 
CPU. 

1.3.6 Remote Descriptor Base Register (RDBR) 

The Remote Descriptor Base Register (RDBR) resides in loca- 
tion B of the CPU Random Access Memory (RAM) , refer to subsection 
4.9.1. The contents of this register point to a table of up to 
4,096 data descriptors. 

1.3.7 Status/Security Register (S) 

The status/security register (S) contains the system status 
and security keys. 
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1.3.8 Stack Pointer (T Register) 

The stack pointer (or T register) resides in location A of 
the RAM. The contents of this register point to the base of the 
current stack structure in memory, 

1-4 DATA WORD FORMATS 

This subsection defines the various data word formats that 
are used by the CPU* 

1.4.1 Memory Data 

All data elements, such as a bit or byte, are based on 16-bit 
memory words. The format of each word is defined from left to 
right with the first bit numbered 0: 



MSB 







15 



LSB 



Memory data may be accessed by instructions to the bit, byte, 
digit, word, or multiword data item level. In all cases, the 
leftmost element is the most significant element of the word; 
e.g., bit (above) is the first bit, bit 1 is the second bit, 
bits through 7 are the first byte, bits 8 through 15 are the 
second byte, etc. Multiword items require successive word loca- 
tions; the lowest address is defined as the leftmost or most sig- 
nificant part of the data item. 

1.4.2 Addresses 

An address pointer is used to point to bit, byte, word, 
or multiword data items. This address indicates the leftmost and 
most significant element of- the data item. Within an array, data 
items are numbered from left to right. 

The CPU may operate in either Long or Short Address Form (LAF 
or SAF) . LAF provides virtual addressability to 1M words, where- 
as SAF provides addressability to 64K words. Addresses are un- 
signed. Physical byte addresses must be presented to the Megabus 
and must contain 24 bits. 

23 



Megabus Address 



Bit positions of processor address registers are numbered to 
correspond to their positions on the Megabus with an appropriate 
number of leading zeros. 

The CPU generates addresses which may contain 21 significant 
bits: 



2 3 



23 



I MB2 
L - 



Address 
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1.4,3 Signed Integer Data Word 

The data field is a 16-bit integer (in two's complement form 
with the radix point to the right of bit 15, the least signifi- 
cant bit. Bit indicates the Sign (S) of the data field. The 
format of the signed integer data word is: 



1 



15 



Data 



S = Zero, sign is positive. 
S * One? sign is negative. 

1,4.4 Signed Integer Data Byte 

The data field is an 8-bit integer (in two's complement form) 
with the radix point to the right of bit 7, the least significant 
bit. Bit indicates the Sign (S) of the data field- The format 
of the signed integer data byte is: 

1 7 



Data 



S = Zero; sign is positive. 
S = One; sign is negative. 

1.4.5 Sign Extended Integer Byte in Word 

The data field is a 16-bit integer (in two's complement form) 
with the radix point to the right of bit 15, the least signifi- 
cant bit. The Sign bit (S) is extended from bit 8 through bit U 
of the data word. The format of the sign extended byte in a word 



is: 



7 8 9 



15 



SSSSSSSS 



Data 



S ■ Zero; sign is positive. 
S ■ One; sign is negative. 

1.4.6 Unsigned Integer Word 

The data field is a 16-bit integer. The format of the un- 
signed integer word is as follows: 

15 

Data 
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1.4.7 Unsigned Integer Byte 

The data field is an 8-bit integer. The format of the un- 
signed integer byte is as follows: 

7 



Data 



1.4.8 Unsigned Integer Byte in Word 

The data field is an 8-bit integer and bits through 7 are 
Zero. The format of the unsigned integer byte in a word is: 



7 8 



15 



All Zeros 



Data 



1.4.9 Signed Integer Double-Word 

The data field is a 32-bit integer (in two's complement form) 
with the radix point to the right of bit 31 # the least signifi- 
cant bit. Bit indicates the Sign (S) of the data field. The 
format of the signed integer double-word is as follows: 



1 



15 16 

1 

Data 



31 



S - Zero; sign is positive. 
S = One; sign is negative. 

1.5 INSTRUCTION WORD FORMATS 

The CPU instruction set is divided into eight categories: 

• Double-operand instructions 

• Single- operand instructions 

• Input /Output instructions 

• Short value immediate instructions 

• Branch on register instructions 

• Branch on indicator instructions 

• Shift instructions 

• Generic instructions. 

For a complete list of Level 6 instructions and their defini- 
tions, refer to the Honeywell Level 6 Minicomputer Handbook 
(order number AS22) . 

The double-operand and single-operand type instructions use 
an Address Syllable (AS) field to generate address references. A 
decode of the AS field usually results in the formulation of an 
Effective Address (EA) , which points to an operand. The address 
syllable can take one of the following three formats: 
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1- Register AS (RAS) : The source or destination of the 
operand is a register (D or B ) . 

2 - immediate Operand (IMP): The operand follows the in- 
struction (special case of MAS, see item J). 

-*- Memory AS (MAS) : This fotm specifies a memory location 
that contains the operand. 

1.5.1 Double-Operand Instructions 

Double-operand instructions have the following format: 

13 4 8 5 15 



1 


# 


Op 


AS 



Op = op-code field 

If = register number 
AS = Address Syllable; refer to subsection 1.6 for the 
AS format. 

Within this group, three types of instruction are available: 
(1) address register instructions, (2) data register instruc- 
tions, and (3) mode register instructions. The type of register 
(D, B, or M) selected by the register number field is a function 
of the op-code. Depending on whether the address syllable speci- 
fies RAS, MAS, or IMO format, these instructions are defined as 
having the following formats, respectively: 



RR 
RM 
RI 



Register to Register 
Register to Memory 
Reg ister Immediate 



1.5.2 Single-Operand Instructions 

Single-operand instructions have the following format: 
13 4 8 9 15 



Op 
AS 



1 





Op 


AS 



op-code field 

Address Syllable; refer 

AS format. 



to subsection 1.6 for the 



Within the group, three types of instructions are available: 
(1) control instructions, (2) bit instructions, and (3) modify 
operand instructions. Depending on whether the address syllable 
specified RAS, MAS, or IMO format, these instructions are defined 
as having the following formats, respectively: 
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Register only 
Memory only 
Immediate only 



NOTE 

Some instructions that modify operands in memory op- 
erate in the Read Modify Write (RMW) mode- In this 
mode, the selected memory cannot be accessed by any 
other processor in RMW mode until the location is 
modified by the current RMW. This feature is useful 
for synchronization in a multiprocessor environment. 

1,5.3 Input /Output Instructions 

The I/O instructions are defined by their format as follows: 

• Data and command I/O instructions 

• Address and range output instruction. 

1.5.3.1 Data and Command I/O Instructions 

These instructions specify two quantities: (1) the data word 
that is identified by an address syllable identical to the one 
used for single-operand instructions, and (2) the control word 
that identifies the external channel (or device) and the function 
it has to perform. The control word may be imbedded in the pro- 
cedure as follows: 



U 1 



3 4 



8 9 



15 



1 





Op 


DAS 


Additional word if needed by DAS 
(refer to subsection 1.6) 


CH 


F 



Control 
Word 

or it may be nonprocedural, in which case the format is as 

follows : 






1 3 


4 8 


9 15 


1 





Op 


DAS 


Additional word if needed by DAS 


000000000 


CAS 


Additional word if needed by CAS 



. Points to 
I Control Word 
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Op = op-code field. 

DAS = Data Address Syllable; specifies the location from/to 
which the data are transferred to/from the Megabus 
(refer to subsection 1.6 for DAS format). 

CH = Channel number or the device address- 

F = Function code, where: 

• if F is even, data are transferred from the controller 
to the CPU. 

• If F is odd, data are transferred from the CPU to the 
controller . 

CAS = Controll Address Syllable; points to control word that 
contains CH and F (refer to subsection 1.6 for CAS 
format) . 

1.5.3.2 Address and Range Output Instructions 

This instruction specifies three quantities: (1) the ad- 
dress, which is identified by an address syllable that is identi- 
cal to the one used for single operand instruct ions , {2) the con- 
trol word, which identifies the external channel (or device) and 
the function it has to perform, and (3) the range which is iden- 
tified by an address syllable. The control word may be imbedded 
in the procedure as follows: 



1 



3 4 



8 9 



15 



1 


Op 


AAS 


Additional word if needed by *AAS 


CH 


F(09) 


000000000 


RAS 


Additional word if needed by RAS 
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or it may be nonprocedural , in which case the format is as 
follows : 



1 



3 4 



8 9 



15 



1|0 


Op 


AAS 


Additional word if needed by AAS 


000000 00 


CAS 


Additional Word if needed by CAS 


OOOOOCOOO 


RAS 


Additional word if needed by RAS 



The definitions of the above words are the same as those spe- 
cified in subsection 1,5.3.1 with the following additions: 

AAS = Address Address Syllable; the byte effective address 

formulation from the AAS is transferred to the Megabus 
(refer to subsection 1.6 for AAS format). 

RAS = Range Address Syllable; specifies the location from 
which the range is transferred to the Megabus (refer 
to subsection 1.6 for RAS format) . 

F = Function code,- must specify the function code that is 
used to load the channel address register? otherwise, 
the operation is unspecified. 

NOTE 

All 1/0 instructions are privileged. If the privi- 
ilege bit is zero, a trap will result (using trap 
vector 13) in lieu of execution (refer to Table 2-5). 

1.5.4 S hort Value Immediate Instructions 

Short value immediate instructions have the following format: 

13 4 7 8 15 






# 


Op 


V 



Op = op-code filed* 

# = register number; selects one of seven word operand 
registers . 

V = immediate operand value; the value is between -128 and 
+127, inclusive . 
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These instructions operate on the word operand (D) registers and 
perform the following operations : 

• Load 

• Compare 

• Add 

• Multiply. 

1 ,5.5 Branch On Register Instructions 

Branch on register instructions have the following format: 
13 4 8 9 15 






# 


Op 


d 



Op = op-code field. 

# = register number; selects one of seven word operand 
registers . 

d = displacement; the relative address of the branch 
destination (refer to subsection 1.6.1) . 

These instructions enable branching on specified conditions of a 
selected word operand register, such as: 

• Equal to zero 

• Less than zero 

• Increment and test 

• Decrement and test. 

1 .5.6 Branch on Indicator Instructions 

Branch on indicator instructions have the following format: 
13 4 8 9 15 











Op 



Op ■ op-code field. 

d = displacement; the relative address of the branch 
destination (refer to subsection 1.6.1) . 

These instructions enable branching on various indicators, such 
as : 



Carry 
Equal 
Less than 
Greater than 
I/O bit . 
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1.5.7 Shi ft Instructions 

The shift instructions have two formats: shift short and 
shift long. 

1.5.7.1 Shift Short Format 

The shift short instruction format is as follows: 

1 3 4 7 8 9 11 12 15 







1 




oj # 


0000 


0| T 


d 



# = register number; selects one of seven word operand 
registers. 

T = type and direction of the shift. 

d = distance (value between 1 and 15, inclusive); if d = r 
substitute the contents of Dl (bits 12 through 15) for 
distance . 

1.5.7.2 Shift Long Format 

The shift long instruction format is as follows: 

1 3 4 7 8 9 10 11 15 



1 ° 


# 


0000 |l| T 


d 



f = register number; selects one of three word operand 
register pairs . 

T = type and direction of the shift. 

d = distance (value between 1 and 31, inclusive); if d = 0, 
substitute the contents of Dl (bits 11 through 15) for 
d i stance . 

Various types of shifts on single or double operands (two 
registers linked together) are possible; e.g., closed, open f 
arithmetic, left, right, etc. For double-operand shifts, the 
register number must equal 3, 5, or 7; otherwise, the operation 
is unspecified. The pairing of the registers is as follows: 



#J # 

2 3 

4 5 

6 7 



#■ = the number of the implied register that is linked 
together with the selected register (#) . 
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Some shift operations modify the Carry (C) or Overflow (OV) 
indicators. The Carry indicator reflects the state of the last 
bit shifted out. If the Carry or Overflow indicator is to be 
modified and the actual shift distance is zero, the Carry or 
Overflow indicator is clear. 

1.5.8 Generic Instructions 

The generic instructions have the following format: 

7 8 15 



00000000 



F 



Additional words as needed 



F - function code: 

Within this group, the following types of instructions are 

available : 



1. 

2. 

3. 

4. 

5. 

6. 

7. 

8. 

9. 
10. 
11. 
12. 
13. 
14. 
15. 
16. 
17. 
18. 
19. 
20. 



Acquire Stack Space 

Activate Segment Descriptor 

Breakpoint Trap 

Control Real-Time Clock 

Control Watchdog Timer 

Dequeue On Address 

Dequeue From Head 

Halt 

Load Remote Descriptor Base 

Load Stack Pointer 

Mem ory-To -Memory Move 

Monitor Call 

Queue On Head 

Queue On Tail 

Reconfigure External Processor 

Relinquish Stack Space 

Return From Trap 

Store Stack Pointer 

Store Remote Descriptor Base 

Validate Address, Range, and Access Rights 



1.6 CPU /MEMORY EFFECTIVE ADDRESSING 



Address generation depends on 
contained in the instruction. 



the following address types 



• Displacement 

• Address Syllable 

In some cases, the contents of the Program Counter (P) are 
used to generate the effective address,- P is assumed to be 
pointing to the word that contains the displacement in question 
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1.6,1 Pi spldcement Add cess Tyge 

The first type of address definition field is the displace- 
ment type used with branch on register and branch on indicator 
instructions (refer to subsection 1.5.5 and 1.5.6, respectively). 

The formulation of the effective address is: 

1. If d = r the effective address is obtained from the 
second (and third) word(s) of the instruction. 

2. If d = 1, the effective address is obtained by adding to 
P the Displacement (DSP) contained in the second word of 
the instruction. 

3. If d * or 1, the effective address is obtained by 
adding the displacement (a two's complement number with 

a value between -64 and +63, inclusive) to the address of 
the instruction (P) . 



1,6.2 Address Syllable 

The single-operand and double-operand 

address references through a field called 
(AS). The format of the address syllable 



instructions generate 
the Address Syllable 
is ; 



11 1213 



15 



m 


9 


n 



m = address modifier, 

@ = indirect addressing bit. 

n = register number; values between and 7, inclusive. 

Figure 1-4 is a representation of the complete address sylla- 
ble. Table 1-1 lists a set of definitions to facilitate the use 
of these AS descriptions. 

1.6.2.1 Register Address Syllable 

The Register Address Syllable (RAS) addresses a register that 
is the source or destination for the operand. The following sub- 
set of Figure 1-4 is defined as RAS: 



m 


N > 


e = o 


5 


B register or 
D register 
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n=0 


n>0 


m 


P-0 


?=1 


£-0 




@=1 









IMA 


*IMA 


Bn 


*Bn 


1 


IMA+D1 


*ima+di 


Bn+Dl 


*Bn+Dl 


2 


IMA+D2 


*IMA+D2 


Bn+D2 


*3r.+D2 


3 


IMA+D3 


*IMA+D3 


Bn+D3 


*Bn+D3 


4 


P+DSP 


*{P+DSP) 


Bn+DSP 


* (Bn+DSP) 


5 


RFU 


RFC 


Bn register 
or 

Dn register 


n=l,2, or 3 

Bn + *D1 


n-4 
RFU 


n=5 r 6, 
B(n-4j 


or 7 
+ Dlt 


6 


RFU 


RFU 


iBn 


n=l r 2, or 3 

Bn t- JD2 


n=4 
RFU 


n=5,6, 
B(n-4) 


or 7 

i- D2t 


7 


IMO 


IV+DSP 

i 


Bnf 


B"l.| 2, or 3 

Bn + J D3 


n=4 
RFU 


n=5,6, 
B(n-4) 


or 7 

+ D3t 



NOTE 

Entries in this figure are mnemonics for the various 
address forms available. These forms are described 
in subsections 1,6.1 through 1.6.3. 



Figure 1-4 Address Syllable 
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Table 1-1 Address Syllable Notation 



NOTATION 



DSP 



T 

I 
IMA 

B 

D 

P 



[] 

+ 

x 

«- 

EA 
IEA 
I MO 
TV 



DESCRIPTION 



DSP indicates a 16-bit signed displacement that tollowi 
the address syllable 

Indirect operator (^ @) 

Specifies indexing 

Auto-increment (BT or Dt indicates postincrementation) 

Auto-decrement {IB or ID indicates predecrertentation) 

Immediate Address 

Base register 

Operand register 

Program counter; for the purpose of P relative address 
ing, P points to the word containing the displacement 

Logical binding 

Contents of 

Addition operator 

Subtraction operator 

Multiplication operator 

Is replaced by 

Effective Address 

Intermediate Address 

Immediate Operand 

Interrupt Vector (points to Interrupt Save Area of 
Current Level} 



1-19 



The interpretation of RAS is determined by the op-code. For 
op-codes on Base (B) registers, RAS is defined as follows: 



m 


n > 


@ = 


5 


B register 



Select word operand register n (n = value between 1 and 7, 
inclusive) . 

For all other single-operand and double-operand instructions, 
excluding LAB f LNJ, JMP, ENT , SAVE, and RSTR, RAS is defined as 
follows: 



m 


n > 


e - o 


5 


D register 



Selects word operand register n (n = value between 1 and 7, 
inclusive) . 

1.6.2.2 Immediate Operand Address Syllable 

The Immediate Operand Address Syllable (IMO) specifies an 
operand of appropriate size, which immediately follows the in- 
struction. The following subset of Figure 1-4 is defined as IMO 



m 


n - 


@ - 


7 


IMO 



1.6.2.3 Memory Address Syllable 

The Memory Address Syllable (MAS) specifies the effective ad 
dress of a memory location. The MAS can have one of three for- 
mats: (1) P relative, (2) Immediate Address, or (3) B relative. 

P Relative Format 

The P Relative format is as follows: 



m 


n 


= 


@ = 


9-1 


4 


P + DSP 


* (P + DSP) 
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P + DSP: The effective address is formed by adding DSP to the 
contents of P 

MP + DSP): The effective address is pointed to by P + DSP. 

Immediate Address Format 

The Immediate Address (IMA) format is as follows: 



m 


n = 





@ = 


§ = 1 





IMA 


*IMA 


1 


IMA + Dl 


*IMA + Dl 


2 


IMA + D2 


*IMA + D2 


3 


IMA + D3 


*IMA + D3 



IMA: in laf, use the two words that follow the address syllable 
as shown below: 







a 9 



15 





AS 


MBZ (TV15) 


3 


6 


7 


(SB) 


22 



IMA: In SAF , use the 16 bits in the word that follows the ad- 
dress syllable: 



AS 



22 



*IMA: The effective address is contained in the location(s) 
pointed to by IMA (* is the indirect operator) . 

IMA + D (1, 2, or 3): The effective address is IMA indexed by 
the appropriate index register (see the following notes). 

*IMA + D (1, 2, or 3): The effective address is obtained by 
adding the contents of the appropriate index register to the 
contents of the location (s) pointed to by IMA; indirect, post 
indexing (see the following notes). 
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NOTES 

1. If the operand is larger or smaller than 16 bits, 
scale the index value before adding. 

2. If in the LAF raode, indirection extracts a double- 
word (IMA and IMA + 1) as follows; 



C 



1112 



15 



MBZ (TV15) 



^ 



22 



B Relative Format 



The B Relative format is as follows: 



m 


n > 


@ = 


e = i 





Bn 


*Bn 


1 


Bn + Dl 


*Bn + Dl 


2 


Bn + D2 


*Bn + D2 


3 


Bn + D3 


*Bn + D3 


4 


Bn + DSP 


+ (Bn + DSP) 


5 




n = 1,2,3 
Bn + 4.D1 


n = 5,6,7 

B(n-4) + D1T 


6 


Bn 


n = 1,2,3 

Bn + iD2 


n = 5,6,7 
B{n-4) + D2T 


7 


Bn 


n = 1,2,3 

Bn + j,D3 


n = 5,6,7, 
B{n-4) + D3T 



Bn: The effective address is contained in base register n 
(n = value between 1 and 7 r inclusive). 

*Bn: The effective address is contained in the memory loca- 
tion pointed to by base register n (n = value between 1 and 7, 
inclusive) . 
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Bn + Dl, D2, or D3: The effective address is obtained by adding 
the contents of the appropriate index register to the contents of 
base register n (n = value between 1 and 7, inclusive). Refer to 
the following note. 

*Bn + Dl, D2, or D3: The effective address is obtained by adding 
the contents of the appropriate index register to the contents of 
the memory location(s) pointed to by base register n (n = value 
between 1 and 7, inclusive). Refer to the following note. 

NOTE 

If the operand is larger or smaller than 16 bits, 
scale the index value before adding- 

Bn + DSP: The effective address is obtained by adding DSP to the 
contents of base register n (n = value between 1 and 7, inclu- 
sive) . 

*(Bn + DSP): The effective address is contained in the loca- 
tion(s) pointed to by Bn + DSP (n = value between 1 and 7, inclu- 
sive) . 

IBn: The effective address is contained in base register n after 
it is decremented by the operand size in words (n - value between 
1 and 7 f inclusive). 

BnT: The effective address is contained in base register n (n = 
value between 1 and 7, inclusive). The base register is incre- 
mented by the operand size in words after effective address for- 
mation and prior to instruction execution. 

Bn + Dx: The effective address is obtained by adding the con- 
tents of the appropriate (n - 4) index register (after it is de- 
cremented by 1) to the contents of the selected (n - 4) base re- 
gister. If the operand is larger or smaller than 16 bits, the 
index value is scaled to operand size before addition. 

B (n-4) + Dx: The effective address is obtained by adding the 
contents of the appropriate (m - 4) index register to the con- 
tents of the selected (n - 4) base register. After effective 
address formation and prior to execution of the op-code, the 
selected index register is incremented by 1, If the operand is 
larger or smaller than 16 bits f the index value is scaled to 
operand size before addition . 

1.6.3 Indexing 

Many address syllable forms specify indexing. During effec- 
tive address generation, one of three index registers (Dl, D2, or 
D3) is algebraically added as the last step, after any indirec- 
tion, to the base address. The index value is treated as a sign- 
ed integer data word. 
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While indexing, the hardware automatically aligns the index 
value to correspond to the size of the item being referenced. 
The size of this item is determined by the op-code type (bit, 
byte, digit, word, double-word, or quadruple-word) . 

1*6,3.1 Bit Addressing 

The index value for bit instructions (LB, LBF, LBT, LBC, and 
LBS), where the address syllable calls for indexing (IMA + Dx, 
Bn 4 Dx, *Bn + Dx, etc.), is aligned to denumerate bits in the 
array, with bit being the leftmost bit in word of the array- 
As an example, consider the following instruction. 

LB, Bl + Dl 

If Bl = 100 and Dl = +21, then the addressed bit is bit 15 in 
location 101 . 



U 



5 



15 



Location 

101 











Ar\r\ro<mf>rt Ri + 



If Bl = 100 and Dl = -2, then the addressed bit is bit 14 in 
location FF. 







14 15 



Location 

FF 



Addressed Bit 



1.6.3.2 Byte Addressing 

The index value for byte instructions (LDH, STH, CMH f etc.), 
where the address syllable calls for indexing, is aligned to de- 
numerate bytes in the array, with byte being the leftmost byte 
in word of the array. As an example, considering the following 
instruction: 

LDH, D4, Bl + D2 

If Bl = 200 and Dl = +n, then the addressed byte is as shown 

below; 



Location 

IFF 

Bl = 200 

201 



15 



-2 J-l 



I +1 

— \ 



+ 2 j +3 



1 _T A 



1.6.3.3 Word Addressing 

The index value for word instructions (LDR, ADD, OR, etc.), 
where the address syllable calls for indexing, denumerates words 
in the array, with word being the leftmost word in the array- 
As an example, consider the following instruction. 

ADD, D3, Bl -I- D2 

If Ell = 150 and D2 = +n, then the addressed word is as 
follows: 



Location 
14E 
14F 

Bl = 150 

151 
152 







15 



-2 



-1 



+ 1 



+2 



1.6.3.4 Double-Word Addressing 

The index value for double-word operands, where the address 
syllable calls for indexing, denumerates double-words (32 bits) 
in the array, with the double-word zero (0) being the leftmost 
double-word. The processor assumes double-word operands for the 
following: (1) LDI , SDI , and AID instructions, and (2) scienti- 
fic instructions (except branch instructions) if the memory 
operand length stored in M4 equals 2, and (3) all base register 
instrucitons (LDB, CMN, STB, CMB, and SWB) if the processor is in 
LAF mode. As an illustrative example, consider the following 
instruction . 

LDI, (D6, D7) , B4 + D3 

If B4 = 300 and D3 = +n, then the address operand is as 
follows: 
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2FC 
2FD 
2FE 
2FF 
300 
301 
302 
303 



-2 



-1 







+ 1 



1.6.3.5 Quadruple-Word Addressing 

The index value for scientific instructions (except branch 
instructions) , where the memory operand length equals 4 (stored 
in M4) and the address syllable calls for indexing, assumes an 
array of quadruple words. 

Consider the following example; 

FAD, SI, B5 + Dl 

If B5 » 2000 and Dl = + n , then the addressed operand is as 
follows: 



1FFC 




200U — 



2004 



1.7 MEMORY ADDRESS BOUNDARIES 

When the CPU initiates a memory cycle that addresses non- 
existent memory, the processor either traps (using trap vector 
15, see Table 2-5) or causes undefined results. These boundaries 
are of interest in defining nonexistent memory: 

1. Addresses below zero 

2. Addresses beyond the last module on-line at a given 
installation 
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3. Addresses greater than 1,024 K-words (i.e., main memory 
equals lM-words) . 

If main memory is less than lM-words, violation of any of the 
above three address boundaries causes a trap. If main memory is 
lM-words, then trap conditions caused by incrementing the program 
counter, a hidden register, or a base register may not be detect 
ed and cause undefined results. 

It should be noted that when the memory management unit 
(refer to subsection 1.2) is configured into the system, large 
virtual addresses may roam freely within the CPU and are not 
subjected to the scrutiny previously described until they are 
mapped and deposited onto the Megabus. The memory management 
unit may trap an address for other reasons, for example: 

• Violation of protection (trap vector 14) 

• Attempt to reference an invalid segment (trap vector is) . 
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